Name – Sujit Dhage Roll no = B43007

* ENTITY

![](data:image/png;base64,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)

* VHDL CODE:

-- Company:

-- Engineer:

--

-- Create Date: 09:32:53 09/13/2023

-- Design Name:

-- Module Name: C:/Users/Admin/Desktop/E41101/shiftreg/shiftreg.vhd

-- Project Name: shiftreg

-- Target Device:

-- Tool versions:

-- Description:

--

-- VHDL Test Bench Created by ISE for module: unishiftreg

--

-- Dependencies:

--

-- Revision:

-- Revision 0.01 - File Created

-- Additional Comments:

--

-- Notes:

-- This testbench has been automatically generated using types std\_logic and

-- std\_logic\_vector for the ports of the unit under test. Xilinx recommends

-- that these types always be used for the top-level I/O of a design in order

-- to guarantee that the testbench will bind correctly to the post-implementation

-- simulation model.

LIBRARY ieee;

USE ieee.std\_logic\_1164.ALL;

-- Uncomment the following library declaration if using

-- arithmetic functions with Signed or Unsigned values

--USE ieee.numeric\_std.ALL; ENTITY shiftreg IS

END shiftreg;

ARCHITECTURE behavior OF shiftreg IS

-- Component Declaration for the Unit Under Test (UUT) COMPONENT unishiftreg

PORT(

si : IN std\_logic; clk : IN std\_logic; so : OUT std\_logic;

pin : IN std\_logic\_vector(3 downto 0); po : OUT std\_logic\_vector(3 downto 0); sel : IN std\_logic\_vector(1 downto 0)

);

END COMPONENT;

--Inputs

signal si : std\_logic := '0'; signal clk : std\_logic := '0';

signal pin : std\_logic\_vector(3 downto 0) := (others => '0'); signal sel : std\_logic\_vector(1 downto 0) := (others => '0');

--Outputs signal so : std\_logic;

signal po : std\_logic\_vector(3 downto 0);

-- Clock period definitions

constant clk\_period : time := 10 ns; BEGIN

-- Instantiate the Unit Under Test (UUT) uut: unishiftreg PORT MAP (

si => si,

clk => clk, so => so, pin => pin, po => po, sel => sel

);

-- Clock process definitions clk\_process :process

begin

clk <= '0';

wait for clk\_period/2; clk <= '1';

wait for clk\_period/2; end process;

-- Stimulus process stim\_proc: process begin

-- hold reset state for 100 ns. wait for 100 ns;

wait for clk\_period\*10;

-- insert stimulus here wait;

end process; END;

* TESTBENCH

-- Company:

-- Engineer:

--

-- Create Date: 09:36:30 09/13/2023

-- Design Name:

-- Module Name: C:/Users/Admin/Desktop/E41101/shiftreg/tb.vhd

-- Project Name: shiftreg

-- Target Device:

-- Tool versions:

-- Description:

--

-- VHDL Test Bench Created by ISE for module: unishiftreg

--

-- Dependencies:

--

-- Revision:

-- Revision 0.01 - File Created

-- Additional Comments:

--

-- Notes:

-- This testbench has been automatically generated using types std\_logic and

-- std\_logic\_vector for the ports of the unit under test. Xilinx recommends

-- that these types always be used for the top-level I/O of a design in order

-- to guarantee that the testbench will bind correctly to the post-implementation

-- simulation model.

LIBRARY ieee;

USE ieee.std\_logic\_1164.ALL;

-- Uncomment the following library declaration if using

-- arithmetic functions with Signed or Unsigned values

--USE ieee.numeric\_std.ALL; ENTITY tb IS

END tb;

ARCHITECTURE behavior OF tb IS

-- Component Declaration for the Unit Under Test (UUT) COMPONENT unishiftreg

PORT(

si : IN std\_logic; clk : IN std\_logic; so : OUT std\_logic;

pin : IN std\_logic\_vector(3 downto 0); po : OUT std\_logic\_vector(3 downto 0); sel : IN std\_logic\_vector(1 downto 0)

);

END COMPONENT;

--Inputs

signal si : std\_logic := '0'; signal clk : std\_logic := '0';

signal pin : std\_logic\_vector(3 downto 0) := (others => '0'); signal sel : std\_logic\_vector(1 downto 0) := (others => '0');

--Outputs signal so : std\_logic;

signal po : std\_logic\_vector(3 downto 0);

-- Clock period definitions

constant clk\_period : time := 10 ns; BEGIN

-- Instantiate the Unit Under Test (UUT) uut: unishiftreg PORT MAP (

si => si, clk => clk, so => so, pin => pin, po => po, sel => sel

);

-- Clock process definitions clk\_process :process

begin

clk <= '0';

wait for clk\_period/2; clk <= '1';

wait for clk\_period/2; end process;

-- Stimulus process stim\_proc: process begin

sel <= "00";

si <= '1';

wait for 100 ns;

sel <= "01";

si <= '1';

wait for 100 ns; sel <= "10";

pin <= "1010";

wait for 100 ns;

wait; end process;

END;

* SYNTHESIS REPORT Release 14.1 - xst P.15xf (nt64)

Copyright (c) 1995-2012 Xilinx, Inc. All rights reserved.

--> Parameter TMPDIR set to xst/projnav.tmp Total REAL time to Xst completion: 0.00 secs Total CPU time to Xst completion: 0.11 secs

--> Parameter xsthdpdir set to xst

Total REAL time to Xst completion: 0.00 secs

Total CPU time to Xst completion: 0.11 secs

--> Reading design: unishiftreg.prj

TABLE OF CONTENTS

1. Synthesis Options Summary
2. HDL Compilation
3. Design Hierarchy Analysis
4. HDL Analysis
5. HDL Synthesis
   1. HDL Synthesis Report
6. Advanced HDL Synthesis
   1. Advanced HDL Synthesis Report
7. Low Level Synthesis
8. Partition Report
9. Final Report
   1. Device utilization summary
   2. Partition Resource Summary
   3. TIMING REPORT

=========================================================================

\* Synthesis Options Summary \*

=========================================================================

---- Source Parameters

Input File Name : "unishiftreg.prj"

Input Format : mixed

Ignore Synthesis Constraint File : NO

---- Target Parameters

Output File Name : "unishiftreg"

Output Format : NGC

Target Device : xc3s400-5-pq208

---- Source Options

Top Module Name : unishiftreg Automatic FSM Extraction : YES

FSM Encoding Algorithm : Auto

Safe Implementation : No

FSM Style : LUT

RAM Extraction : Yes

RAM Style : Auto

ROM Extraction : Yes

Mux Style : Auto

Decoder Extraction : YES Priority Encoder Extraction : Yes

Shift Register Extraction : YES

Logical Shifter Extraction : YES

XOR Collapsing : YES

ROM Style : Auto

Mux Extraction : Yes

Resource Sharing : YES

Asynchronous To Synchronous : NO

Multiplier Style : Auto

Automatic Register Balancing : No

|  |  |
| --- | --- |
| ---- Target Options |  |
| Add IO Buffers | : YES |
| Global Maximum Fanout | : 100000 |
| Add Generic Clock Buffer(BUFG) | : 8 |
| Register Duplication | : YES |
| Slice Packing | : YES |
| Optimize Instantiated Primitives | : NO |
| Use Clock Enable | : Yes |
| Use Synchronous Set | : Yes |
| Use Synchronous Reset | : Yes |
| Pack IO Registers into IOBs | : Auto |
| Equivalent register Removal | : YES |

---- General Options

Optimization Goal : Speed

Optimization Effort 1

Keep Hierarchy : No

Netlist Hierarchy : As\_Optimized RTL Output : Yes

Global Optimization : AllClockNets Read Cores : YES

Write Timing Constraints : NO

Cross Clock Analysis : NO

|  |  |
| --- | --- |
| Hierarchy Separator | : / |
| Bus Delimiter | : <> |
| Case Specifier | : Maintain |
| Slice Utilization Ratio | : 100 |
| BRAM Utilization Ratio | : 100 |
| Verilog 2001 | : YES |
| Auto BRAM Packing | : NO |
| Slice Utilization Ratio Delta | : 5 |

=========================================================================

=========================================================================

\* HDL Compilation \*

=========================================================================

Compiling vhdl file "C:/Users/Admin/Desktop/E41101/shiftreg/unishiftreg.vhd" in Library work. Architecture behavioral of Entity unishiftreg is up to date.

=========================================================================

\* Design Hierarchy Analysis \*

=========================================================================

Analyzing hierarchy for entity <unishiftreg> in library <work> (architecture <behavioral>).

=========================================================================

\* HDL Analysis \*

=========================================================================

Analyzing Entity <unishiftreg> in library <work> (Architecture <behavioral>). Entity <unishiftreg> analyzed. Unit <unishiftreg> generated.

=========================================================================

* HDL Synthesis \*

=======================================================================

Performing bidirectional port resolution... Synthesizing Unit <unishiftreg>.

Related source file is "C:/Users/Admin/Desktop/E41101/shiftreg/unishiftreg.vhd".

WARNING:Xst:647 - Input <pin> is never used. This port will be preserved and left unconnected if it belongs to a top-level block or it belongs to a sub-block and the hierarchy of this sub-block is preserved.

Found 1-bit register for signal <so>. Found 4-bit register for signal <po>. Found 4-bit register for signal <temp>. Summary:

inferred 9 D-type flip-flop(s).

Unit <unishiftreg> synthesized.

=========================================================================

HDL Synthesis Report Macro Statistics

# Registers 3

1-bit register 1

4-bit register 2

=========================================================================

=========================================================================

* Advanced HDL Synthesis \*

=========================================================================

=========================================================================

Advanced HDL Synthesis Report Macro Statistics

# Registers 9

Flip-Flops 9

=========================================================================

=========================================================================

* Low Level Synthesis \*

=========================================================================

Optimizing unit <unishiftreg> ...

Mapping all equations...

Building and optimizing final netlist ...

Found area constraint ratio of 100 (+ 5) on block unishiftreg, actual ratio is 0. Final Macro Processing ...

=========================================================================

Final Register Report Macro Statistics

# Registers 9

Flip-Flops 9

=========================================================================

=========================================================================

* Partition Report \*

========================================================================

Partition Implementation Status

No Partitions were found in this design.

=========================================================================

* Final Report \*

=========================================================================

|  |  |
| --- | --- |
| Final Results |  |
| RTL Top Level Output File Name | : unishiftreg.ngr |
| Top Level Output File Name | : unishiftreg |
| Output Format | : NGC |
| Optimization Goal | : Speed |
| Keep Hierarchy | : No |
| Design Statistics |  |
| # IOs | : 13 |
| Cell Usage : |  |
| # BELS | : 6 |
| # LUT2 | : 2 |
| # LUT3 | : 4 |
| # FlipFlops/Latches | : 9 |
| # FD | : 4 |
| # FDE | : 5 |
| # Clock Buffers | : 1 |
| # BUFGP | : 1 |
| # IO Buffers | : 8 |
| # IBUF | : 3 |
| # OBUF | : 5 |

=========================================================================

Device utilization summary:

Selected Device : 3s400pq208-5

Number of Slices: 5 out of 3584 0% Number of Slice Flip Flops: 9 out of 7168 0% Number of 4 input LUTs: 6 out of 7168 0%

|  |  |  |  |
| --- | --- | --- | --- |
| Number of IOs: | 13 |  | |
| Number of bonded IOBs: | 9 out of | 141 | 6% |
| Number of GCLKs: | 1 out of | 8 | 12% |

Partition Resource Summary:

No Partitions were found in this design.

========================================================================= TIMING REPORT

NOTE: THESE TIMING NUMBERS ARE ONLY A SYNTHESIS ESTIMATE.

FOR ACCURATE TIMING INFORMATION PLEASE REFER TO THE TRACE REPORT GENERATED AFTER PLACE-and-ROUTE.

Clock Information:

+ + +

Clock Signal | Clock buffer(FF name) | Load |

+ + +

clk | BUFGP | 9 |

+ + + Asynchronous Control Signals Information:

No asynchronous control signals found in this design Timing Summary:

Sped Grade: -5

Minimum period: 2.230ns (Maximum Frequency: 448.340MHz) Minimum input arrival time before clock: 3.538ns

Maximum output required time after clock: 6.216ns Maximum combinational path delay: No path found

Timing Detail:

All values displayed in nanoseconds (ns)

=========================================================================

Timing constraint: Default period analysis for Clock 'clk' Clock period: 2.230ns (frequency: 448.340MHz) Total number of paths / destination ports: 12 / 9

- Delay: 2.230ns (Levels of Logic = 1)

Source: temp\_3 (FF)

Destination: temp\_2 (FF)

Source Clock: clk rising Destination Clock: clk rising Data Path: temp\_3 to temp\_2

Gate Net

Cell:in->out fanout Delay Delay Logical Name (Net Name)

FD:C->Q 4 0.626 0.949 temp\_3 (temp\_3)

LUT3:I1->O 1 0.479 0.000 temp\_mux0000<2>1 (temp\_mux0000<2>)

FD:D 0.176 temp\_2

Total 2.230ns (1.281ns logic, 0.949ns route) (57.4% logic, 42.6% route)

=========================================================================

Timing constraint: Default OFFSET IN BEFORE for Clock 'clk' Total number of paths / destination ports: 15 / 9

- Offset: 3.538ns (Levels of Logic = 2)

Source: sel<0> (PAD)

Destination: po\_0 (FF) Destination Clock: clk rising Data Path: sel<0> to po\_0

Gate Net

Cell:in->out fanout Delay Delay Logical Name (Net Name)

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| IBUF:I->O | 2 | 0.715 | 1.040 | sel\_0\_IBUF (sel\_0\_IBUF) |
| LUT2:I0->O | 4 | 0.479 | 0.779 | po\_cmp\_eq00001 (po\_cmp\_eq0000) |
| FDE:CE |  | 0.524 |  | po\_0 |

Total 3.538ns (1.718ns logic, 1.820ns route) (48.6% logic, 51.4% route)

=========================================================================

Timing constraint: Default OFFSET OUT AFTER for Clock 'clk' Total number of paths / destination ports: 5 / 5

- Offset: 6.216ns (Levels of Logic = 1)

Source: so (FF)

Destination: so (PAD)

Source Clock: clk rising Data Path: so to so

Gate Net

Cell:in->out fanout Delay Delay Logical Name (Net Name)

|  |  |  |  |
| --- | --- | --- | --- |
| FDE:C->Q | 1 | 0.626 | 0.681 so (so\_OBUF) |
| OBUF:I->O |  | 4.909 | so\_OBUF (so) |

Total 6.216ns (5.535ns logic, 0.681ns route) (89.0% logic, 11.0% route)

=========================================================================

Total REAL time to Xst completion: 4.00 secs Total CPU time to Xst completion: 3.87 secs

-->

Total memory usage is 4493172 kilobytes Number of errors : 0 ( 0 filtered) Number of warnings : 1 ( 0 filtered) Number of infos : 0 ( 0 filtered)

* + UCF FILE

NET "Clk" LOC = "P182"; NET "Rst" LOC = "P102";

NET "Mode(0)" LOC = "P93";

NET "Mode(1)" LOC = "P90";

NET "si" LOC = "P101"; NET "so" LOC = "p181";

NET "pin(0)" LOC = "P87";

NET "pin(1)" LOC = "P86";

NET "pin(2)" LOC = "P85";

NET "pin(3)" LOC = "P81";

NET "pin(4)" LOC = "P80";

NET "pin(5)" LOC = "P78";

NET "pin(6)" LOC = "P77";

NET "pin(7)" LOC = "P74";

NET "po(0)" LOC = "P162";

NET "po(1)" LOC = "P165";

NET "po(2)" LOC = "P166";

NET "po(3)" LOC = "P167";

NET "po(4)" LOC = "P168";

NET "po(5)" LOC = "P171";

NET "po(6)" LOC = "P172";

NET "po(7)" LOC = "P175";